博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
首页列表显示全部问答,完成问答详情页布局。
阅读量:4687 次
发布时间:2019-06-09

本文共 6400 字,大约阅读时间需要 21 分钟。

  1. 首页列表显示全部问答:
    1. 将数据库查询结果传递到前端页面 Question.query.all()
    2. 前端页面循环显示整个列表。
    3. 问答排序
  2. 完成问答详情页布局:
    1. 包含问答的全部信息
    2. 评论区
    3. 以往评论列表显示区。
  3. 在首页点击问答标题,链接到相应详情页。
    from flask import Flask,render_template,request,redirect,url_for,sessionfrom flask import Flaskfrom flask_sqlalchemy import SQLAlchemyimport configfrom functools import wrapsfrom datetime import datetimeapp = Flask(__name__)#app.config['SECRET_KEY'] = '1234567'app.config.from_object(config)db = SQLAlchemy(app)class User(db.Model):    __tablename__ = 'user_test'    id=db.Column(db.Integer,primary_key=True,autoincrement=True)    username=db.Column(db.String(20),nullable=False)    password = db.Column(db.String(20), nullable=False)    nickname = db.Column(db.String(20))    tel = db.Column(db.String(20))class Question(db.Model):    __tablename__ = 'question'    id=db.Column(db.Integer,primary_key=True,autoincrement=True)    title = db.Column(db.String(100),nullable=False)    detail = db.Column(db.Text,nullable=False)    creat_time = db.Column(db.DateTime,default=datetime.now)    author_id = db.Column(db.Integer,db.ForeignKey('user_test.id'))    author = db.relationship('User',backref=db.backref('question'))# db.create_all()#2.在表中插入一条记录#user = User(username = 'mis1',password = '124', nickname='wk')#db.session.add(user)#db.session.commit()#3.去表中查询用户名对应的密码和接下来用户输入的密码是否相匹配#user = User.query.filter(User.username == 'mis1234').first()#print(user)#print(user.id,user.username)#输出查找到的用户名的id,密码等.#修改查询到的用户名的密码等#user = User.query.filter(User.username == 'mis1234').first()#user.password = '123'#db.session.commit()#再次插入一条记录# user = User(username = 'wkkkkkk',password = '123456', nickname='kk')# db.session.add(user)# db.session.commit()#删除一条记录#user = User.query.filter(User.username == 'mis1234').first()#db.session.delete(user)#db.session.commit()@app.route('/')def index():    context={        'questions':Question.query.all()    }    return render_template('index.html',**context)@app.route('/detail/
    ')def detail(question_id): return render_template('detail.html',ques = question_id)@app.route('/login/',methods=['GET','POST'])def login(): if request.method == 'GET': return render_template('login.html') else: usern = request.form.get('uname') passw = request.form.get('upass') user = User.query.filter(User.username==usern).first() if user: if user.password == passw: session['user'] = usern; return redirect(url_for('index')) else: return 'password error!' else: return 'username is not exister!'@app.route('/register/',methods=['GET','POST'])def register(): if request.method =='GET': return render_template('register.html') else: usern = request.form.get('uname') teln = request.form.get('number') passw = request.form.get('upass') user = User.query.filter(User.username==usern).first() if user: return 'username existed' else: user1= User(username=usern,tel=teln,password=passw) db.session.add(user1) db.session.commit() return redirect(url_for('login'))@app.context_processordef mycontext(): usern = session.get('user') if usern: return{
    'username':usern} else: return {}def loginFirst(func): @wraps(func) def wrapper(*args,** kwargs): if session.get('user'): return func(*args,** kwargs) else: return redirect(url_for('login')) return wrapper@app.route('/logout/')def logout(): session.clear() return redirect(url_for('index'))@app.route('/question/',methods=['GET','POST'])@loginFirstdef question(): if request.method =='GET': return render_template('question.html') else: biaoti = request.form.get('biaoti') detail = request.form.get('detail') author_id = User.query.filter(User.username==session.get('user')).first().id question = Question(title=biaoti,detail=detail,author_id=author_id) db.session.add(question) db.session.commit() return redirect(url_for('index'))@app.route('/questionDetail/')def questionDetail(): return render_template('questionDetail.html')if __name__ == '__main__': app.run(debug=True)
        
    首页
    {#login#}{#register#}{#question#}

    {

    { username }}context

        
    问答详情页
    {#login#}{#register#}{#question#}

    {

    { username }}context

    title

    {

    { username }} creat_time

    评论:
    {#
    #}

转载于:https://www.cnblogs.com/wk15/p/7989058.html

你可能感兴趣的文章
配置NRPE的通讯
查看>>
shp系列(一)——利用C++进行shp文件的读(打开)与写(创建)开言
查看>>
匹配两个空格之间的字符。。。
查看>>
CSS 文字溢出 变成省略号 ...
查看>>
Spring事务
查看>>
java编程基础(三)流程控制语句
查看>>
让数据库跑的更快的7个MySQL优化建议
查看>>
jquery 取id模糊查询
查看>>
解决在vue中,自用mask模态框出来后,下层的元素依旧可以滑动的问题
查看>>
修改node节点名称
查看>>
PAT(B) 1014 福尔摩斯的约会(Java)
查看>>
PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树
查看>>
项目开发总结报告(GB8567——88)
查看>>
SSH加固
查看>>
端口扫描base
查看>>
iOS IM开发的一些开源、框架和教程等资料
查看>>
FansUnion:共同写博客计划终究还是“流产”了
查看>>
python 二维字典
查看>>
pip 警告!The default format will switch to columns in the future
查看>>
Arrays类学习笔记
查看>>